#include<bits/stdc++.h>
using namespace std;
struct s
{
	long long zhi;
}a[1000000];
long long n,Q;
int main()
{
	freopen("sort.in","r",stdin);
	freopen("sort.out","w",stdout);
	scanf("%lld%lld",&n,&Q);
	for(int i=1;i<=n;i++)
	{
		scanf("%lld",&a[i].zhi);
	}
	for(int i=1;i<=Q;i++)
	{
		int cz=0;
		long long v=0,x=0,n=0;
		scanf("%lld",&cz);
		if(cz==1)
		{
			scanf("%lld%lld",&x,&v);
			a[x].zhi=v;
		}
		else
		{
			long long zhao,wz;
			scanf("%lld",&zhao);
			wz=zhao;
			for(int i=zhao-1;i>=1;i--)
			{
				if(a[i].zhi>a[zhao].zhi)
				{
					wz--;
				}
			}
			for(int i=zhao+1;i<=n;i++)
			{
				if(a[i].zhi<a[zhao].zhi)
				{
					wz++;
				}
			}
			printf("%lld\n",wz);
		}
	}
	
	return 0;
}
